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WHAT IS CLAIMED IS: 

<zy^ 1 A system for retrieval and processing of a data set from one or more data 
sources comprising: 

a query structure assembly module for defining a query structure based 
upon ^plurality of query assembly rules and a desired data set; 

syntax assembly module for defining at least one query language 
statemen\ based upon the defined query structure; 

a process optimization module for evaluating processing options based 
upon a database schema associated with the data source; and 

whereby at least one query language statement may assembled and run 
against the da\a source(s) to return the desired data result set. 

2. The sysrem of claim 1, wherein the process optimization module includes 
a table selection moduleYor evaluating the size of a selected set of tables from the 
database schema. 

3. The system df claim 1, wherein the process optimization module includes 
an intermediate data processing selection module for evaluating the reusability of an 
intermediate data set in returning the defined data result set. 

4. The system of claiVi 1, wherein the process optimization module includes 
an intermediate data processing method module for evaluating a plurality of methods for 
generating intermediate data sets witmin the data source(s). 

5. The system of claim 1, ^herein the process optimization module includes 
a join path selection module for evaluating the length of at least one join path used in 
returning the defined data result set. 



6. The system of claim 1, whereimthe query structure assembly module 
accesses a query assembly rule associated with ^selected database management system. 
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7. The system ofrclaim 1, wherein the syntax assembly module accesses a 
syntax description associated with a selected database management system. 

\ 

8. The system of claim 1, wherein the process optimization module accesses 
a query assembly rule, a syntax description, or a syntax pattern associated with a selected 

5 database management system. I 

\ 

i 
\ 

9. The system of claim|l, wherein the system is a component in an online 
analytical processing systems, a reporting system, a business intelligence system, or a data 
mining system. 

^ 10. A method of generating a query language statement to be run against one 

^lO or more data sources, comprising the steps of: 
Q;| generating a query struoture based upon a database schema associated with 

3.3 1 

™ the data source and a desired da\a result set; 

*5 generating query language syntax based upon the query structure for 

s returning the desired data result sett from the data source(s); and 

SU5 evaluating a plurality of quory assembly rules, syntax descriptions, or 

^ syntax patterns for process optimization. 

U 11. The method of claim 10, wherein the step of evaluating the plurality of 

query assembly rules, syntax descriptions, or sWax patterns for process optimization 
includes evaluating the size of a plurality of sets\of identified tables for returning the 
20 desired data result set. 

12. The method of claim 10, wherein thA step of evaluating the plurality of 
query assembly rules, syntax descriptions, or syntax patterns for process optimization 
includes evaluating the reusability of intermediate data sets. 
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13. The method of claim 10, wherein the step of evaluating the plurality of 
query assembly rules, syntax descriptions, or syntax patterns for process optimization 
includes evaluating a plurality of methods for generating intermediate data sets. 



14. The method of claim 10^ wherein the step of evaluating a plurality of query 
assembly rules, syntax descriptions, or syntax patterns for process optimization includes 
evaluating a plurality of join paths used in returning the desired data result set. 

15. The method of claim 10, wherein the step of evaluating a plurality of query 
assembly_rules, syntax descriptions, or symtax patterns for process optimization includes 
evaluating at least one query assembly rule, syntax description, or syntax pattern 
associated with a selected database management system. 

16. The method of claim 10, wherein the step of generating a query structure 
includes evaluating at least one query assembly rule associated with a selected database 
management system. 1 

17. The method of claim 10, wherein the step of generating query language 
syntax includes evaluating at least one syntax description or syntax pattern associated 
with a selected database management system! 

18. The method of claim 10, wherdin the method is implemented in an online 
analytical processing systems, a reporting system, a business intelligence system, or a data 
mining system. \ 

19. A medium having a processor readable program code embodied therein for 
retrieving and processing data from one or morejdata sources comprising: 

code for causing the processor to evaluate a plurality of sets of tables 
within the data source(s) for generating a desired data result set; 

code for causing the processor to evaluate at least one intermediate data set 
for reusability in generating the desired datairesult set; 
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code for causing the processor^ to evaluate a plurality of methods for 
generating intermediate data sets for use in generating the desired data result set; 

code for causing the processor to evaluate a plurality of join paths used for 
joining tables to return the desired data result set; and 

code for causing the processor to assemble at least one query language 
statement based upon the evaluations of the plurality of sets of tables, the at least 
one intermediate data set, the pluralitylof methods for generating intermediate data 
sets, and the plurality of join paths. 

20. The medium of claim 19, further comprising code for causing the 
processor to evaluate at least one query assembly rule associated with a selected database 
management system. 
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